package com.ethan.crm.mapper;

import com.ethan.crm.domain.Employee;
import com.ethan.crm.query.EmployeeQueryObject;
import org.apache.ibatis.annotations.Param;

import java.util.List;

public interface EmployeeMapper {
    int deleteByPrimaryKey(Long id);

    int insert(Employee record);

    Employee selectByPrimaryKey(Long id);

    List<Employee> selectAll();

    int updateByPrimaryKey(Employee record);

    int updateState(Long id);

    /**
     * 根据用户名和密码查询员工信息
     * @param username
     * @param password
     * @return
     */
    Employee getEmployeeForLogin(@Param("username") String username, @Param("password")String password);

    /**
     * 查询员工总数
     * @param qo
     * @return
     */
    Long queryForPageCount(EmployeeQueryObject qo);

    /**
     * 分页查询所有员工信息
     * 注意学习下oracle和mysql的分页方式
     * @param qo
     * @return
     */
    List<Employee> queryForPage(EmployeeQueryObject qo);

    /**
     * 新增员工和角色的关系信息
     * @param rid   角色ID主键
     * @param eid   员工ID主键
     * @return
     */
    int insertEmpAndRoleRelation(@Param("rid") Long rid,@Param("eid")Long eid);

    void deleteRolesOfEmpByEid(Long eid);

}